<?php
/**
 * @title 5476. 找出数组游戏的赢家 - 不借助max
 * @author start2004
 */

class Solution {

    /**
     * @param Integer[] $arr
     * @param Integer $k
     * @return Integer
     */
    function getWinner($arr, $k) {
        /**
         * @since 2020-08-03 数组长度
         */
        $len=count($arr);

        /**
         * @since 2020-08-03 结果集
         */
        $result = false;

        /**
         * @since 2020-08-03 依次找每个数字获胜次数
         */
        $prefix = 0;
        for($i=0; $i<$len;) {
            /**
             * @since 2020-08-03 后续在遇到比他大之前, 有多少个数比他小
             */
            $less = 0;
            for($j=$i+1; $j<$len; $j++){
                if($arr[$i]>$arr[$j]){
                    $less++;
                } else {
                    break;
                }
            }

            /**
             * @since 2020-08-03 是否符合条件
             */
            if($less+$prefix >= $k){
                $result = $arr[$i];
                break;
            } else {
                if($j == $len){
                    $result = $arr[$i];
                    break;
                } else {
                    /**
                     * @since 2020-08-03 检查剩余长度是否足够
                     */
                    if(($len-$j) >= $k){
                        $prefix = 1;
                        $i = $j;
                    } else {
                        /**
                         * @since 2020-08-03 剩余长度不够, 直接max, break
                         */
                        break;
                    }
                }
            }
        }

        /**
         * @return
         */
        return $result;
    }
}




/**
 * @url http://127.0.0.1/leetcode/202008/2020.08.02_2.php
 */
$datas = [
    [[2,1,3,5,4,6,7], 2],
    [[3,2,1], 10],
    [[1,9,8,2,3,7,6,4,5], 7],
    [[1,11,22,33,44,55,66,77,88,99], 1000000000],
];

include_once dirname(__DIR__) . DIRECTORY_SEPARATOR ."xhprof.php";
$xhprof = new Xhprof();
foreach ($datas as $data){
    var_dump($data);

    $obj = new Solution();
    $result = $obj->getWinner($data[0], $data[1]);
    var_dump($result);
    echo str_repeat("<br>", 3);
}
$xhprof->end();
